SQL UNION Operator

இரண்டு அல்லது அதற்கு மேற்பட்ட SELECT statements-ன் முடிவு-தொகுப்புகளை இணைக்க UNION operator பற்றி அறிந்து கொள்ளுங்கள்

SQL UNION Operator என்றால் என்ன?

UNION operator இரண்டு அல்லது அதற்கு மேற்பட்ட SELECT statements-ன் முடிவு-தொகுப்புகளை இணைக்கப் பயன்படுகிறது.

UNION operator தானாகவே முடிவு தொகுப்பில் இருந்து நகல் வரிசைகளை நீக்குகிறது.

UNION-க்கான தேவைகள்:

  • UNION-ல் உள்ள ஒவ்வொரு SELECT statement-க்கும் ஒரே எண்ணிக்கையிலான நெடுவரிசைகள் இருக்க வேண்டும்
  • நெடுவரிசைகளும் ஒத்த தரவு வகைகளைக் கொண்டிருக்க வேண்டும்
  • ஒவ்வொரு SELECT statement-ல் உள்ள நெடுவரிசைகளும் ஒரே வரிசையில் இருக்க வேண்டும்

UNION தொடரியல்

SELECT column_name(s) FROM table1
UNION
SELECT column_name(s) FROM table2;

குறிப்பு:

முடிவு-தொகுப்பில் உள்ள நெடுவரிசை பெயர்கள் பொதுவாக முதல் SELECT statement-ல் உள்ள நெடுவரிசை பெயர்களுக்குச் சமமாக இருக்கும்.

ஆர்ப்பாட்ட தரவுத்தளம்

இந்த பயிற்சியில் நாம் நன்கு அறியப்பட்ட Northwind மாதிரி தரவுத்தளத்தைப் பயன்படுத்துவோம்.

"Customers" அட்டவணையில் இருந்து ஒரு தேர்வு கீழே உள்ளது:

Customers அட்டவணை

+------------+--------------------------------+----------------+-------------------+----------+------------+---------+
| CustomerID | CustomerName                   | ContactName    | Address           | City     | PostalCode | Country |
+------------+--------------------------------+----------------+-------------------+----------+------------+---------+
| 1          | Alfreds Futterkiste            | Maria Anders   | Obere Str. 57     | Berlin   | 12209      | Germany |
| 2          | Ana Trujillo Emparedados...    | Ana Trujillo   | Avda. Constitución| México   | 05021      | Mexico  |
| 3          | Antonio Moreno Taquería        | Antonio Moreno | Mataderos 2312    | México   | 05023      | Mexico  |
+------------+--------------------------------+----------------+-------------------+----------+------------+---------+

மற்றும் "Suppliers" அட்டவணையில் இருந்து ஒரு தேர்வு:

Suppliers அட்டவணை

+------------+-----------------------------+-------------------+-----------------+-------------+------------+---------+
| SupplierID | SupplierName                | ContactName       | Address         | City         | PostalCode | Country |
+------------+-----------------------------+-------------------+-----------------+-------------+------------+---------+
| 1          | Exotic Liquid               | Charlotte Cooper  | 49 Gilbert St.  | London       | EC1 4SD    | UK      |
| 2          | New Orleans Cajun Delights  | Shelley Burke     | P.O. Box 78934  | New Orleans  | 70117      | USA     |
| 3          | Grandma Kelly's Homestead   | Regina Murphy     | 707 Oxford Rd.  | Ann Arbor    | 48104      | USA     |
+------------+-----------------------------+-------------------+-----------------+-------------+------------+---------+

SQL UNION உதாரணம்

பின்வரும் SQL statement "Customers" மற்றும் "Suppliers" அட்டவணைகளில் இருந்து நகரங்களை (தனித்த மதிப்புகள் மட்டும்) திரும்பப் பெறுகிறது:

உதாரணம்

SELECT City FROM Customers
UNION
SELECT City FROM Suppliers
ORDER BY City;

முடிவு

City
Ann Arbor
Berlin
London
México
New Orleans

குறிப்பு:

சில வாடிக்கையாளர்கள் அல்லது சப்ளையர்கள் ஒரே நகரத்தைக் கொண்டிருந்தால், ஒவ்வொரு நகரமும் ஒருமுறை மட்டுமே பட்டியலிடப்படும், ஏனெனில் UNION தனித்த மதிப்புகளை மட்டுமே தேர்ந்தெடுக்கிறது. நகல் மதிப்புகளையும் தேர்ந்தெடுக்க UNION ALL-ஐப் பயன்படுத்தவும்!

WHERE உடன் SQL UNION

பின்வரும் SQL statement "Customers" மற்றும் "Suppliers" அட்டவணைகளில் இருந்து ஜெர்மன் நகரங்களை (தனித்த மதிப்புகள் மட்டும்) திரும்பப் பெறுகிறது:

உதாரணம்

SELECT City, Country FROM Customers
WHERE Country='Germany'
UNION
SELECT City, Country FROM Suppliers
WHERE Country='Germany'
ORDER BY City;

மற்றொரு UNION உதாரணம்

பின்வரும் SQL statement அனைத்து வாடிக்கையாளர்களையும் சப்ளையர்களையும் பட்டியலிடுகிறது:

உதாரணம்

SELECT 'Customer' AS Type, ContactName, City, Country
FROM Customers
UNION
SELECT 'Supplier', ContactName, City, Country
FROM Suppliers;

முடிவு

Type
ContactName
City
Country
Customer
Maria Anders
Berlin
Germany
Customer
Ana Trujillo
México
Mexico
Customer
Antonio Moreno
México
Mexico
Supplier
Charlotte Cooper
London
UK
Supplier
Shelley Burke
New Orleans
USA
Supplier
Regina Murphy
Ann Arbor
USA

கவனிக்க:

மேலே உள்ள "AS Type" - இது ஒரு alias. SQL Aliases ஒரு அட்டவணை அல்லது நெடுவரிசைக்கு தற்காலிக பெயர் வழங்க பயன்படுகின்றன. ஒரு alias query-ன் கால அளவில் மட்டுமே இருக்கும். எனவே, இங்கே நாம் "Type" என்று பெயரிடப்பட்ட ஒரு தற்காலிக நெடுவரிசையை உருவாக்கியுள்ளோம், இது தொடர்பு நபர் "Customer" அல்லது "Supplier" என்பதை பட்டியலிடுகிறது.

UNION காட்சிப் பிரதிநிதித்துவம்

Customers நகரங்கள்

Berlin
México
México
London
UNION

Suppliers நகரங்கள்

London
New Orleans
Ann Arbor

UNION முடிவு

Ann Arbor
Berlin
London
México
New Orleans

கவனிக்க: UNION தானாகவே நகல் மதிப்புகளை நீக்குகிறது. "México" மற்றும் "London" இரண்டு அட்டவணைகளிலும் இருந்தாலும், அவை முடிவில் ஒருமுறை மட்டுமே தோன்றும்.

UNION தேவைகள் விரிவாக

நெடுவரிசைகளின் எண்ணிக்கை

ஒவ்வொரு SELECT statement-க்கும் ஒரே எண்ணிக்கையிலான நெடுவரிசைகள் இருக்க வேண்டும்

-- சரி
SELECT Name, City FROM Table1
UNION
SELECT Name, City FROM Table2

-- தவறு
SELECT Name, City FROM Table1
UNION
SELECT Name FROM Table2

தரவு வகைகள்

நெடுவரிசைகள் ஒத்த தரவு வகைகளைக் கொண்டிருக்க வேண்டும்

-- சரி
SELECT Name, Age FROM Table1
UNION
SELECT Product, Quantity FROM Table2

-- தவறு
SELECT Name, Age FROM Table1
UNION
SELECT Product, Date FROM Table2

நெடுவரிசை வரிசை

நெடுவரிசைகள் ஒரே வரிசையில் இருக்க வேண்டும்

-- சரி
SELECT FirstName, LastName FROM Table1
UNION
SELECT FirstName, LastName FROM Table2

-- தவறு
SELECT FirstName, LastName FROM Table1
UNION
SELECT LastName, FirstName FROM Table2

பயிற்சி

பின்வரும் SQL statement-ல் என்ன பிழை உள்ளது?

SELECT CustomerName, City FROM Customers
UNION
SELECT SupplierName FROM Suppliers;
தவறான அட்டவணை பெயர்கள்
✗ தவறு! அட்டவணை பெயர்கள் சரியாக உள்ளன
நெடுவரிசைகளின் எண்ணிக்கை பொருந்தவில்லை
✓ சரி! முதல் SELECT-ல் 2 நெடுவரிசைகள் உள்ளன, இரண்டாவது SELECT-ல் 1 நெடுவரிசை மட்டுமே உள்ளது
தவறான keyword பயன்பாடு
✗ தவறு! UNION keyword சரியாக பயன்படுத்தப்பட்டுள்ளது
தரவு வகைகள் பொருந்தவில்லை
✗ தவறு! நெடுவரிசைகளின் எண்ணிக்கை முதலில் சரிபார்க்கப்பட வேண்டும்